/*
 * To change this template, choose Tools | Templates
 * and open the template in the editor.
 */
package com.supinfo.youfood.dao.jpa;

import com.supinfo.youfood.dao.Commande_ProduitDao;
import com.supinfo.youfood.entity.Commande;
import com.supinfo.youfood.entity.Commande_Produit;
import com.supinfo.youfood.entity.Produit;
import java.util.ArrayList;
import java.util.List;
import javax.ejb.Stateless;
import javax.persistence.EntityManager;
import javax.persistence.PersistenceContext;
import javax.persistence.Query;

/**
 *
 * @author Michael
 */
@Stateless
public class JpaCommande_ProduitDao implements Commande_ProduitDao{
    
    @PersistenceContext
    private EntityManager em;

    @Override
    public Commande_Produit addCommande_Produit(Commande c, Produit p) {
        Commande_Produit cp = new Commande_Produit(p, c);
        em.persist(cp);
        return cp;
    }

    @Override
    public List<Commande_Produit> getCommandesAF(List<Commande_Produit> lcp) {
        List<Commande_Produit> res = new ArrayList<Commande_Produit>();
        String query = "SELECT cp "+
                        "FROM Commande_Produit cp "+
                        "WHERE cp.etat = :etat";
        Query result = em.createQuery(query);
        result.setParameter("etat", 1);
        res = result.getResultList();
        return res;
    }

    @Override
    public List<Commande_Produit> getCommandesEnCours(List<Commande_Produit> lcp) {
        List<Commande_Produit> res = new ArrayList<Commande_Produit>();
        String query = "SELECT cp "+
                        "FROM Commande_Produit cp "+
                        "WHERE cp.etat = :etat";
        Query result = em.createQuery(query);
        result.setParameter("etat", 2);
        res = result.getResultList();
        return res;
    }

    @Override
    public List<Commande_Produit> getCommandesFinis(List<Commande_Produit> lcp) {
        List<Commande_Produit> res = new ArrayList<Commande_Produit>();
        String query = "SELECT cp "+
                        "FROM Commande_Produit cp "+
                        "WHERE cp.etat = :etat";
        Query result = em.createQuery(query);
        result.setParameter("etat", 3);
        res = result.getResultList();
        return res;
    }

    @Override
    public Commande_Produit findCommande_ProduitById(Long id) {
        return em.find(Commande_Produit.class, id);
    }

    @Override
    public void updateCommande_Produit(Commande_Produit cp) {
        em.merge(cp);
    }
}
